
/* 全局样式 */
* {
    margin: 0; /* 去除所有元素的外边距 */
    padding: 0; /* 去除所有元素的内边距 */
    box-sizing: border-box; /* 设置盒模型为 border-box 使得 padding 和 border 计算在宽高之内 */
    list-style: none; /* 去除列表项的默认样式 */
    text-decoration: none; /* 去除文本的下划线 */
}

/* body 样式 */
body {
    background: #fff; /* 设置背景颜色为白色 */
}

/* section 样式 */
section {
    position: relative; /* 使元素相对定位 */
    width: 100%; /* 宽度占满100% */
    height: 100vh; /* 高度占满整个视口 */
    display: flex; /* 使用 Flexbox 布局 */
    justify-content: center; /* 水平居中对齐 */
    align-items: center; /* 垂直居中对齐 */
    font: 700 100px ''; /* 设置字体样式 */
    color: #aca541; /* 设置文本颜色 */
    background: #fff; /* 背景颜色为白色 */
}

/* 侧边栏样式 */
.shell {
    position:fixed; /* 固定定位，随页面滚动不动 */
    width: 45px; /* 初始宽度为84px */
    height: 100%; /* 高度占满100% */
    background: #000; /* 背景颜色为黑色 */
    z-index: 9999; /* 设置层级，确保在最上方 */
    transition: width 0.5s; /* 宽度变化时的过渡效果 */
    padding-left: 10px; /* 左内边距 */
    overflow: hidden; /* 隐藏超出部分 */
}

/* 悬停效果时改变侧边栏宽度 */
.shell:hover {
    width: 250px; /* 悬停时宽度变为200px */
}

/* 图片框样式 */
.imageBox img {
    width: 50%; /* 图片宽度占满100% */
    height: 50%; /* 图片高度占满100% */
    object-fit: cover; /* 确保图片按比例填充容器 */
}

/* 侧边栏列表样式 */
.shell ul {
    position: relative; /* 相对定位 */
    height: 100vh; /* 高度占满视口 */
}

/* 列表项样式 */
.shell ul li {
    position: relative; /* 相对定位 */
    padding: 5px; /* 内边距 */
}

/* 活动状态样式 */
.active {
    background: #ffffff; /* 背景颜色为白色 */
    border-top-left-radius: 50px; /* 边角圆润 */
    border-bottom-left-radius: 50px; /* 边角圆润 */
    /* opacity: 1; 透明度为1; */
}

/* 活动状态之前的伪元素样式 */
.active::before {
    content: ""; /* 伪元素内容为空 */
    position: absolute; /* 绝对定位 */
    top: -30px; /* 距离顶部30px */
    right: 0; /* 右边对齐 */
    width: 30px; /* 宽度30px */
    height: 30px; /* 高度30px */
    border-bottom-right-radius: 25px; /* 圆角 */
    box-shadow: 5px 5px 0 5px #fffcfc; /* 阴影效果 */
    background: transparent; /* 背景透明 */
}

/* 活动状态之后的伪元素样式 */
.active::after {
    content: ""; /* 伪元素内容为空 */
    position: absolute; /* 绝对定位 */
    top: 0; /* 距离顶部30px */
    right: 0; /* 右边对齐 */
    width: 30px; /* 宽度30px */
    height: 30px; /* 高度30px */
    border-bottom-right-radius: 30px; /* 圆角 */
    box-shadow: 5px -5px 0 5px #fffcfc; /* 阴影效果 */
    background: transparent; /* 背景透明 */
}

/* logo 样式 */
#logo {
    margin: 40px 0 50px 0; /* 外边距设置 */
}

/* 列表链接样式 */
.shell ul li a {
    position: relative; /* 相对定位 */
    display: flex; /* 使用 Flexbox 布局 */
    white-space: nowrap; /* 防止换行 */
}

/* 图标样式 */
.icon {
    position: relative; /* 相对定位 */
    display: flex; /* 使用 Flexbox 布局 */
    justify-self: center; /* 自我居中 */
    align-items: center; /* 垂直居中对齐 */
    min-width: 80px; /* 最小宽度为60px */
    padding-left: 10px; /* 左内边距 */
    height: 80px; /* 高度为60px */
    color: #333; /* 字体颜色 */
    transition: 0.5s; /* 过渡效果 */
    color: rgb(255, 255, 255); /* 字体颜色为白色 */
}

/* 图标内的图标样式 */
.icon i {
    font-size: 100px; /* 字体大小为30px */
    z-index: 999; /* 设置层级 */
}

/* 文本样式 */
.text {
    position: relative; /* 相对定位 */
    height: 60px; /* 高度为60px */
    display: flex; /* 使用 Flexbox 布局 */
    align-items: center; /* 垂直居中对齐 */
    font-size: 15px; /* 字体大小为15px */
    color: #ffad32c1; /* 字体颜色 */
    padding-left: 15px; /* 左内边距 */
    text-transform: uppercase; /* 大写字母 */
    letter-spacing: 2px; /* 字母间距 */
    transition: 0.5s; /* 过渡效果 */
}

/* 悬停效果时改变文字颜色 */
.shell ul li:hover a .icon,
.shell ul li:hover a .text {
    color: #ffa117; /* 悬停时颜色变更 */
}

/* 活动状态下图标之前的伪元素样式 */
.active a .icon::before {
    content: ""; /* 伪元素内容为空 */
    position: absolute; /* 绝对定位 */
    inset: 5px; /* 四边距5px */
    width: 60px; /* 宽度60px */
    background: #000; /* 背景为黑色 */
    border-radius: 50%; /* 圆形边框 */
    transition: 0.5s; /* 过渡效果 */
    border: 7px solid #ffa117; /* 边框样式 */
    box-sizing: border-box; /* 包含内边距和边框 */
}
/* *{
    margin: 0;
    padding: 0;
    box-sizing: border-box;
    list-style: none;
    text-decoration: none;
}
body{
    background: #fff;
}
section{
    position: relative;
    width: 100%;
    height:100vh;
    display: flex;
    justify-content: center;
    align-items: center;
    font: 700 100px '';
    color: #aca541;
    background: #fff;
}
.shell{
    position: fixed;
    width: 84px;
    height: 100%;
    background: #000;
    z-index: 9999;
    transition: width 0.5s;
    padding-left: 10px;
    overflow: hidden;
}
.shell:hover{
    width: 200px;
}
.imageBox img{
    width: 100%;
    height: 100%;
    object-fit: cover;
}
.shell ul{
    position: relative;
    height: 100vh;
}
.shell ul li{
    position: relative;
    padding: 5px;
}
.active{
    background: #ffffff;
    border-top-left-radius: 50px;
    border-bottom-left-radius: 50px;
}
.active::before{
    content: "";
    position: absolute;
    top:-30px;
    right: 0;
    width: 30px;
    height:30px;
    border-bottom-right-radius: 25px;
    box-shadow: 5px 5px 0 5px #fffcfc;
    background: transparent;
}
.active::after{
    content: "";
    position: absolute;
    top:-30px;
    right: 0;
    width: 30px;
    height:30px;
    border-bottom-right-radius: 25px;
    box-shadow: 5px -5px 0 5px #fffcfc;
    background: transparent;
}
#logo{
    margin: 40px 0 100px 0;
}
.shell ul li a{
    position: relative;
    display: flex;
    white-space: nowrap;
}
.icon{
    position: relative;
    display: flex;
    justify-self: center;
    align-items: center;
    min-width: 60px;
    padding-left: 10px;
    height: 60px;
    color: #333;
    transition: 0.5s;
    color: rgb(255, 255, 255);
}
.icon i{
    font-size: 30px;
    z-index: 999;
}
.text{
    position: relative;
    height: 60px;
    display: flex;
    align-items: center;
    font-size: 15px;
    color: #ffad32c1;
    padding-left: 15px;
    text-transform: uppercase;
    letter-spacing: 2px;
    transition: 0.5s;
}
.shell ul li:hover a .icon,
.shell ul li:hover a .text{
    color: #ffa117;
}
.active a .icon::before{
    content: "";
    position: absolute;
    inset: 5px;
    width: 60px;
    background: #000;
    border-radius: 50%;
    transition: 0.5s;
    border: 7px solid #ffa117;
    box-sizing: border-box;
} */